﻿using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using System.Data;
using System.Windows.Forms;

namespace UIT_CV_Management
{
    public class ThucTap
    {
         //ID
        public String maThucTap;
        public String maDiaDiem;

        //Properties
        DateTime ngayBatDau;
        DateTime ngayKetThuc;
        String noiDungThucTap;

        // object
        DiaDiemThucTap diaDiemThucTap
        {
            get
            {
                return new DiaDiemThucTap(maDiaDiem);
            }
            set
            {
                diaDiemThucTap = value;
            }
        }

        //database
        Database myDatabase = Database.shareDatabase;

        public ThucTap(DateTime _ngayBatDau, DateTime _ngayKetThuc, String _noiDungThucTap,DiaDiemThucTap _diaDiemThucTap)
        {
            //ID
            maThucTap = this.getIDFromDatabase();
            maDiaDiem = _diaDiemThucTap.maDiaDiem;

            //Properties
            ngayBatDau = _ngayBatDau;
            ngayKetThuc = _ngayKetThuc;
            noiDungThucTap = _noiDungThucTap;

            // object
            diaDiemThucTap = _diaDiemThucTap;

            
        }
        public ThucTap(String _maThucTap)
        {
            QueryResult result = myDatabase.Query("SELECT * FROM ThucTap WHERE MaThucTap = '" + _maThucTap + "'");
            if (result.ReturnCode == 200)
            {
                DataTable table = result.Table;

                //ID
                maThucTap = table.Rows[0]["MaThucTap"].ToString();
                maDiaDiem = table.Rows[0]["MaDiaDiem"].ToString();

                //Properties
                ngayBatDau = table.Rows[0].Field<DateTime>("NgayBatDau");
                ngayKetThuc = table.Rows[0].Field<DateTime>("NgayKetThuc");
                noiDungThucTap = table.Rows[0]["NoiDungThucTap"].ToString(); 

            }
        }
        private String getIDFromDatabase()
        {
            String x;
            x = Database.getID("ThucTap", "MaThucTap");
            return x;
        }
        public void save()
        {
            String sqlThucTapSinh = "INSERT INTO ThucTap VALUES('" + maThucTap + "','" + ngayBatDau.Date.ToString("yyyy-MM-dd HH:mm:ss") + "','" + ngayKetThuc.Date.ToString("yyyy-MM-dd HH:mm:ss") + "','" + maDiaDiem + "','" + noiDungThucTap + "')";
            QueryResult result = myDatabase.Query(sqlThucTapSinh);

            if (result.ReturnCode == 409)
            {
                MessageBox.Show("Lỗi khi lưu dữ liệu Thực Tập Sinh vào database", "Lỗi", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
            else
            {
                diaDiemThucTap.save();
            }
        }
        public void update()
        {
            bool isDupplicated = Database.isDupplicate("ThucTap", "MaThucTap", maThucTap);

            // update
            if (isDupplicated)
            {
                String sqlUpdate = "UPDATE ThucTap SET NgayBatDau = '" + ngayBatDau.Date.ToString("yyyy-MM-dd HH:mm:ss") + "', NgayKetThuc = '" + ngayKetThuc.Date.ToString("yyyy-MM-dd HH:mm:ss") + "', NoiDungThucTap = '" + noiDungThucTap
                    + "' WHERE MaThucTap = '" + maThucTap + "'";
                QueryResult result = myDatabase.Query(sqlUpdate);

                if (result.ReturnCode == 409)
                    MessageBox.Show("Lỗi khi update liệu Thông Tin Phụ vào database", "Lỗi", MessageBoxButtons.OK, MessageBoxIcon.Error);
                else
                {

                }

            }
        }
        public void delete()
        {
            String sqlDelete = "DELETE FROM ThucTap WHERE MaThucTap = '" + maThucTap + "'";
            QueryResult result = myDatabase.Query(sqlDelete);

            if (result.ReturnCode == 409)
                MessageBox.Show("Lỗi xoá dữ liệu trong database.", "Lỗi", MessageBoxButtons.OK, MessageBoxIcon.Error);
            else
            {
                diaDiemThucTap.delete();
            }
        }
    }
}
